home *** CD-ROM | disk | FTP | other *** search
/ Shareware Grab Bag / Shareware Grab Bag.iso / 010 / shuttle.arc / SHUTTL2.BAS next >
Encoding:
BASIC Source File  |  1985-09-27  |  4.8 KB  |  126 lines

  1. 10 REM REDONE 9/26/85 TO GIVE CONTINUOUS ROTAION OF ANGLES.
  2. 20 REM FIRST X WILL ROTATE FROM 1 TO 360 DEGREES IN 10-DEGREE INCREMENTS
  3. 30 REM X THEN RESETS TO ZERO AN Y ROTATES. THEN Y RESETS AND Z ROTATES
  4. 40 REM
  5. 50 KEY OFF
  6. 60 X=0:Y=0:Z=0:X3=0:Y3=0:Z3=0:AM=0:BM=0:CM=0:DM=0:EM=0:FM=0:GM=0:HM=0:IM=0:D=0:P=0:B=0:H=0:U=0:V=0:U1=0:V1=0
  7. 70 DIM V(300,3),E(300)
  8. 80 CLS
  9. 90 READ NV
  10. 100 FOR P=1 TO NV
  11. 110 READ V(P,1),V(P,2),V(P,3)
  12. 120 V(P,1) = .12 * V(P,1)
  13. 130 V(P,2) = .12 * V(P,2)
  14. 140 V(P,3) = .12 * V(P,3)
  15. 150 NEXT P
  16. 160 READ NE
  17. 170 FOR E=1 TO NE
  18. 180 READ E(E)
  19. 190 NEXT E
  20. 200 SCREEN 2
  21. 210 D=120
  22. 220 QQ=1
  23. 230 FOR Q=0 TO 360 STEP 30
  24. 240 OUT 985,14:LOCATE 1,32:PRINT"                  S P A C E   S H U T T L E   P E R S P E C T I V E"
  25. 250 REM CONTINUE
  26. 260 IF QQ=1 THEN 270  ELSE IF QQ=2 THEN 280  ELSE IF QQ=3 THEN 290
  27. 270 P0=Q:P1=0:P2=0:GOTO 300
  28. 280 P1=Q:P0=0:P2=0:GOTO 300
  29. 290 P2=Q:P0=0:P1=0
  30. 300 LOCATE 23,16:PRINT "          DRAWING X ="P0" Y ="P1" Z ="P2"                   "
  31. 310 P=6.28 * P0 / 255 - 3.1416
  32. 320 B=6.28 * P2 / 255
  33. 330 H=6.28 * P1 / 255
  34. 340 GOSUB 500
  35. 350 XV = -D * CP * SH: REM ---SEE SUB.---
  36. 360 YV = -D * CP * CH
  37. 370 ZV = -D * SP
  38. 380 REM ---PROJECT NE POINTS---
  39. 390 FOR E=1 TO NE
  40. 400 X = V( ABS ( E ( E ) ), 1 )
  41. 410 Y = V( ABS ( E ( E ) ), 2 )
  42. 420 Z = V( ABS ( E ( E ) ), 3 )
  43. 430 GOSUB 630
  44. 440 IF E(E)>0 THEN LINE (U1*2+75,V1+20)-(U*2+75,V+20)
  45. 450 U1 = U: V1 = V
  46. 460 NEXT E
  47. 470 FOR Z=1 TO 1000:NEXT Z:CLS
  48. 480 NEXT Q
  49. 490 QQ=QQ+1:IF QQ<4 THEN 230 ELSE 1250
  50. 500 CH = COS (H): SH = SIN (H)
  51. 510 CP = COS (P): SP = SIN (P)
  52. 520 CB = COS (B): SB = SIN (B)
  53. 530 AM = CB * CH - SH * SP * SB
  54. 540 BM = -CB * SH - SP * CH * SB
  55. 550 CM = CP * SB
  56. 560 DM = SH * CP
  57. 570 EM = CP * CH
  58. 580 FM = SP
  59. 590 GM = -CH * SB - SH * SP * CB
  60. 600 HM = SH * SB - SP * CH * CB
  61. 610 IM = CP * CB
  62. 620 RETURN
  63. 630 X = X - XV
  64. 640 Y = Y - YV
  65. 650 Z = Z - ZV
  66. 660 X3 = AM * X + BM * Y + CM * Z
  67. 670 Y3 = DM * X + EM * Y + FM * Z
  68. 680 Z3 = GM * X + HM * Y + IM * Z
  69. 690 U = 135 + 13.5 * D * X3 / Y3
  70. 700 V = 80 - 11.5 * D * Z3 / Y3
  71. 710 RETURN
  72. 720 DATA 124
  73. 730 DATA 0,-2.2,46,1.5,-2.6,46,2.2,-4.6,46,1.7,-6.5,46,0,-6.7,46
  74. 740 DATA -1.7,-6.5,46,-2.2,-4.6,46,-1.5,-2.6,46
  75. 750 DATA 0,-.8,43,2.8,-1.5,43,4,-4.5,43,3,-7.2,43,0,-8,43,-3,-7.2,43
  76. 760 DATA -4,-4.5,43,-2.8,-1.5,43
  77. 770 DATA 0,1.7,38,4.6,0,38,5.8,-4.4,38,4,-8.2,38,0,-9,38,-4,-8.2,38
  78. 780 DATA -5.8,-4.4,38,-4.6,0,38
  79. 790 DATA 0,4,32.5,4.5,1,32.5,5.8,-4.6,32.5,4,-9,32.5,0,-9.5,32.5,-4,-9,32.5
  80. 800 DATA -5.8,-4.6,32.5,-4.5,1,32.5
  81. 810 DATA 0,8,26.3,3.5,7,26.3,7.8,2,26.3,8,-7,26.3,0,-9.8,26.3,-8,-7,26.3
  82. 820 DATA -7.8,2,26.3,-3.5,7,26.3
  83. 830 DATA 0,8,21.5,3.8,7.5,21.5,8,3,21.5,8,-8,21.5,0,-9.8,21.5,-8,-8,21.5
  84. 840 DATA -8,3,21.5,-3.8,7.5,21.5
  85. 850 DATA 0,8,14,4.7,7,14,8,4,14,8,-8.7,14,0,-10,14,-8,-8.7,14,-8,4,14
  86. 860 DATA -4.7,7,14
  87. 870 DATA 0,8,4,4.7,7,4,8,4,4,8,-8.7,4,0,-10,4,-8,-8.7,4,-8,4,4
  88. 880 DATA -4.7,7,4
  89. 890 DATA 0,8,-12,4.7,7,-12,8,4,-12,8,-8.7,-12,0,-10,-12,-8,-8.7,-12,-8,4,-12
  90. 900 DATA -4.7,7,-12
  91. 910 DATA 0,8,-27.3,4.7,7,-27.3,8,4,-27.3,8,-8.7,-27.3,0,-10,-27.3,-8,-8.7,-27.3
  92. 920 DATA -8,4,-27.3,-4.7,7,-27.3
  93. 930 DATA 0,8,-35.6,4.7,7,-35.6,8,4,-35.6,8,-8.7,-35.6,0,-10,-35.6,-8,-8.7,-35.6
  94. 940 DATA -8,4,-35.6,-4.7,7,-35.6
  95. 950 DATA 0,9,-43,2,8.5,-43,8.8,1.5,-43,9,-10,-43,0,-10.8,-43,-9,-10,-43
  96. 960 DATA -8.8,1.5,-43,-2,8.5,-43
  97. 970 DATA 0,9.5,-48,2,9.3,-48,9.2,1.5,-48,10,-10,-48,0,-10.2,-48,-10,-10,-48
  98. 980 DATA -9.2,1.5,-48,-2,9.3,-48
  99. 990 DATA 8.7,-8.7,21,15,-8.7,-16,35,-10,-36,35,-10,-40
  100. 1000 DATA -8.7,-8.7,21,-15,-8.7,-16,-35,-10,-36,-35,-10,-40
  101. 1010 DATA 0,13,-37,0,33,-60,0,33,-69,0,14,-60
  102. 1020 DATA 6,11,-43,6,11,-48,11,5,-43,11,5,-48,-6,11,-43,-6,11,-48,-11,5,-43
  103. 1030 DATA -11,5,-48
  104. 1040 DATA 259
  105. 1050 DATA -1,2,3,4,5,6,7,8,1,-9,10,11,12,13,14,15,16,9,-17,18,19,20,21,22,23,24,17
  106. 1060 DATA -25,26,27,28,29,30,31,32,25,-33,34,35,36,37,38,39,40,33
  107. 1070 DATA -41,42,43,44,45,46,47,48,41,-49,50,51,52,53,54,55,56,49
  108. 1080 DATA -57,58,59,60,61,62,63,64,57,-65,66,67,68,69,70,71,72,65
  109. 1090 DATA -73,74,75,76,77,78,79,80,73,-81,82,83,84,85,86,87,88,81
  110. 1100 DATA -89,90,91,92,93,94,95,96,89,-97,98,99,100,101,102,103,104,97
  111. 1110 DATA -1,9,17,25,33,41,49,57,65,73,81,89,97
  112. 1120 DATA -2,10,18,26,34,42,50,58,66,74,82,90,98
  113. 1130 DATA -3,11,19,27,35,43,51,59,67,75,83,91,99
  114. 1140 DATA -4,12,20,28,36,44,52,60,68,76,84,92,100
  115. 1150 DATA -5,13,21,29,37,45,53,61,69,77,85,93,101
  116. 1160 DATA -6,14,22,30,38,46,54,62,70,78,86,94,102
  117. 1170 DATA -7,15,23,31,39,47,55,63,71,79,87,95,103
  118. 1180 DATA -8,16,24,32,40,48,56,64,72,80,88,96,104
  119. 1190 DATA -44,105,106,107,108,92
  120. 1200 DATA -46,109,110,111,112,94
  121. 1210 DATA -81,113,114,115,116,89
  122. 1220 DATA -82,117,118,-83,119,120
  123. 1230 DATA -87,121,122,-88,123,124
  124. 1240 DATA -117,119,-121,123,-118,120,-122,124
  125. 1250 END
  126.